.horoscope {
  min-height: 100vh;
}

.zodiac-selector {
  display: flex;
  overflow-x: auto;
  gap: 12px;
  margin: 0 -24px 24px;
  padding: 0 24px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.zodiac-selector::-webkit-scrollbar {
  display: none;
}

.zodiac-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
  padding: 12px;
  border-radius: 12px;
  background-color: var(--card-background);
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
}

.zodiac-item.active {
  background-color: var(--primary-color);
  color: white;
}

.zodiac-emoji {
  font-size: 32px;
  margin-bottom: 8px;
}

.zodiac-name {
  font-size: 14px;
  text-align: center;
}

.zodiac-detail {
  .zodiac-header {
    display: flex;
    align-items: center;
    margin-bottom: 24px;

    .zodiac-large-emoji {
      font-size: 64px;
      margin-right: 20px;
    }

    .zodiac-info {
      flex: 1;

      .zodiac-title {
        font-size: 24px;
        font-weight: 600;
        margin-bottom: 4px;
      }

      .zodiac-date {
        font-size: 16px;
        color: var(--text-secondary);
        margin-bottom: 12px;
      }

      .zodiac-attributes {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;

        .attribute {
          font-size: 14px;
          background-color: var(--background-color);
          padding: 4px 10px;
          border-radius: 12px;
        }
      }
    }
  }

  .fortune-card {
    margin-bottom: 24px;

    .card-title {
      font-size: 18px;
      font-weight: 600;
      margin-bottom: 16px;
    }

    .fortune-text {
      font-size: 16px;
      line-height: 1.5;
      margin-bottom: 20px;
    }

    .fortune-ratings {
      .rating-item {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 12px;

        &:last-child {
          margin-bottom: 0;
        }

        .rating-label {
          font-size: 15px;
        }

        .rating-stars {
          display: flex;
          gap: 2px;

          .star {
            font-size: 16px;
            opacity: 0.3;

            &.active {
              opacity: 1;
            }
          }
        }
      }
    }
  }

  .compatibility-card {
    .card-title {
      font-size: 18px;
      font-weight: 600;
      margin-bottom: 16px;
    }

    .compatibility-content {
      .compatibility-item {
        margin-bottom: 20px;

        &:last-child {
          margin-bottom: 0;
        }

        .compatibility-label {
          font-size: 16px;
          margin-bottom: 12px;
        }

        .compatibility-signs {
          display: flex;
          gap: 24px;

          .compatibility-sign {
            display: flex;
            flex-direction: column;
            align-items: center;

            .sign-emoji {
              font-size: 32px;
              margin-bottom: 8px;
            }

            .sign-name {
              font-size: 14px;
            }
          }
        }
      }
    }
  }
}
